草庐IT

java - iBatis 获取执行sql

全部标签

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur

Ruby:获取哈希中的所有键(包括子键)

让我们有这个散列:hash={"a"=>1,"b"=>{"c"=>3}}hash.get_all_keys=>["a","b","c"]我如何获取所有key,因为hash.keys仅返回["a","b"] 最佳答案 这将为您提供任何嵌套级别的所有键的数组。defget_em(h)h.each_with_object([])do|(k,v),keys|keys1,"b"=>{"c"=>{"d"=>3}}}get_em(hash)#=>["a","b","c","d"] 关于Ruby:获取哈

ruby - 从 Ruby 执行 Rspec

我正在尝试从ruby​​执行rspec,并从方法或类似的东西中获取状态或失败次数。实际上我正在运行这样的东西:system("rspec'myfilepath'")但我只能得到函数返回的字符串。有没有办法直接使用对象来做到这一点? 最佳答案 我认为最好的方法是使用RSpec的配置和格式化程序。这不涉及解析IO流,还以编程方式提供更丰富的结果自定义。RSpec2:require'rspec'config=RSpec.configuration#optionallysettheconsoleoutputtocolourful#equiv

sql - ActiveRecord::StatementInvalid。 PG错误

我正在尝试使用Project.find(id)从Project模型中找到一个项目,但它给了我ActiveRecord::StatementInvalid错误完整跟踪-PG::Error:ERROR:preparedstatement"a1"alreadyexists:SELECTCOUNT(*)FROMpg_classcLEFTJOINpg_namespacenONn.oid=c.relnamespaceWHEREc.relkindin('v','r')ANDc.relname=$1ANDn.nspname=ANY(current_schemas(false))/home/deploy

ruby - "gem install"可以配置为默认安装/usr/bin/外的可执行文件吗?

默认情况下,当您sudogeminstallthegemname时,它会将可执行文件安装到/usr/bin/有办法改变吗?例如,要将它们安装到/usr/local/rubygems/bin(或任何其他路径)?路径似乎没有硬编码到gemspec文件中,所以我不明白为什么这不可能(尽管我对Ruby/Gems的经验很少) 最佳答案 我将此添加为答案,以便当我再次遇到此问题时很明显:)首先,将/var/lib/gems/1.8/bin/中的所有bin移动到/usr/bin/。如果您不这样做,那么卸载或更新gem将不会从原始bin目录中删除二

ruby-on-rails - 我如何在 Rails 的模型中获取 request.uri?

$request=request当我在Controller中编写它时,它会起作用。但是,如果我在模型或应用程序Controller中需要这个变量,我该怎么办? 最佳答案 模型存在于网络请求的上下文之外。您可以在irb中实例化它们,您可以在延迟作业或脚本中实例化它们,等等。如果模型依赖于请求对象,那么这些事情都不可能发生。正如tsdbrown所说,您必须以某种方式从使用模型的上下文中传递该信息。 关于ruby-on-rails-我如何在Rails的模型中获取request.uri?,我们在

ruby - 执行 gem ... ["extconf.rb", ...] 不是文件

我正在尝试围绕C扩展构建一个ruby​​gem。使用rubyextconf.rb可以很好地编译C扩展;制作;sudomakeinstall例程,但是当我尝试使用rake构建gem时,该过程终止并出现此跟踪底部的错误。我正在使用帖子here,具有相同的目录结构,以创建gem。我的配置有什么问题?我的gemspec和Rakefile位于跟踪下方(该gem称为netconf)。//跟踪**Executecopy:netconf:i686-linux:1.9.2install-ctmp/i686-linux/netconf/1.9.2/netconf.solib/netconf/netconf

ruby - 如何在 ruby​​ 中执行 attr_accessor_with_default?

我在Rails模型中使用attr_accessor_with_default的一些代码现在给我一个弃用警告,告诉我“改用Ruby!”所以,考虑到ruby1.9.2中可能有一个新的位使attr_accessor处理默认值,我用谷歌搜索了它,但我没有看到。我确实看到了一堆方法来覆盖attr_accessor来处理默认值。当他们告诉我“使用Ruby”时,这就是他们的意思吗?或者我现在应该写完整的getters/setters吗?或者有什么我找不到的新方法吗? 最佳答案 Thisapidockpage建议只在初始化方法中执行。classSo

ruby - 执行 rake db :migrate on Heroku 时出错

做的时候heroku运行rakedb:migrate所有迁移都已执行,最后我总是收到以下消息:/app/vendor/bundle/ruby/1.9.1/bin/rake:没有这样的文件或目录-pg_dump-i-s-x-O-f/app/db/structure.sqldan79p98fykovu我无法在Heroku上将pg_dump添加到PATH。如何处理? 最佳答案 问题在于,迁移完成后,rails会尝试转储新的structure.sql,但由于pg_dump不存在而失败。为已部署的应用程序生成新的structure.sql毫无

ruby - 在 sinatra 中获取绝对(基本)url

现在,我做一个get'/'doset:base_url,"#{request.env['rack.url_scheme']}://#{request.env['HTTP_HOST']}"#...haml:indexend能够在HAMLindex.haml中使用options.base_url。但我确信有一种更好的、更干的方法可以做到这一点。然而我看不见,也找不到。(我是Sinatra的新手:))不知何故,在get之外,我没有可用的request.env,或者看起来是这样。所以把它放在一个包含中是行不通的。你如何获得你的基本网址? 最佳答案